package com.example.dw.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.dw.entity.CourseType;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 课程类型Mapper接口
 * @author system
 * @since 2024-01-01
 */
@Mapper
public interface CourseTypeMapper extends BaseMapper<CourseType> {

    /**
     * 获取所有课程类型
     */
    @Select("SELECT * FROM course_type ORDER BY createdAt DESC")
    List<CourseType> getAllCourseTypes();

    /**
     * 分页获取课程类型
     */
    @Select("SELECT * FROM course_type ORDER BY createdAt DESC LIMIT #{offset}, #{size}")
    List<CourseType> getCourseTypesByPage(@Param("offset") Integer offset, @Param("size") Integer size);

    /**
     * 获取课程类型总数
     */
    @Select("SELECT COUNT(*) FROM course_type")
    Integer getCourseTypeCount();

    /**
     * 根据ID获取课程类型
     */
    @Select("SELECT * FROM course_type WHERE courseTypeid = #{courseTypeid}")
    CourseType getCourseTypeById(@Param("courseTypeid") Integer courseTypeid);
} 